<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>员工管理</title>
     <#include "../common/link.ftl">
    <script>
        $(function () {
            var $editForm = $("#editForm");
            $editForm.bootstrapValidator({
                feedbackIcons: {
                    valid: 'glyphicon glyphicon-ok',
                    invalid: 'glyphicon glyphicon-remove',
                    validating: 'glyphicon glyphicon-refresh'
                },
                fields: {
                    name: { // name 属性值
                        validators: {
                            notEmpty: { // 非空校验
                                message: '用户名不能为空！'
                            },
                            stringLength: { // 长度校验
                                min: 2,
                                max: 10,
                                message: '用户名长度 %s ~ %s 个字符！'
                            },
                             <#if !employee??>
                                remote: { //远程验证
                                    type: 'post',//请求方式
                                    url: '/employee/checkName.do',//请求路径
                                    message: '用户名已存在',//验证不通过时返回的错误信息
                                    delay: 1000,//一秒后发送一次请求
                                },
                             </#if>
                        }
                    },
                    password: {
                        validators: {
                            notEmpty: {
                                message: '密码不能为空！'
                            },
                            stringLength: {
                                min: 1,
                                max: 12,
                                message: '密码长度 %s ~ %s 个字符！'
                            }
                        }
                    },
                    repassword: {
                        validators: {
                            notEmpty: {
                                message: '确认密码不能为空！'
                            },
                            identical: { // 比较是否相同，否的话校验不通过
                                field: 'password', // 和 password 字段比较
                                message: '两次输入密码不一致！'
                            }
                        }
                    },
                    age: {
                        validators: {
                            notEmpty: {
                                message: '年龄不能为空！'
                            },
                            between: { // 数值范围校验
                                min: 16,
                                max: 60,
                                message: '请输入正常的年龄，范围为 %s 到 %s！'
                            }
                        }
                    },
                    email: {
                        validators: {
                            notEmpty: {
                                message: '邮箱不能为空！'
                            },
                            emailAddress: { // 可以不用自己写正则
                                message: '邮箱格式不正确！'
                            }
                        }
                    }
                }
                //表单所有数据验证通过后执行该方法
            }).on('success.form.bv', function (e) {
                // 禁止原本的表单提交 Prevent form submission
                e.preventDefault();
                //设置右边的所有option为选中状态
                $(".selfRoles option").prop("selected", true);
                // 使用表单异步提交
                $('#editForm').ajaxSubmit(function (data) {
                    if (data.success) {
                        $.messager.confirm('温馨提示', data.msg, function () {
                            window.location.href = '/employee/list.do';
                        });
                    } else {
                        $.messager.alert('温馨提示', data.msg);
                    }
                });
            });
        })
    </script>
</head>
<body class="hold-transition skin-blue sidebar-mini">
<div class="wrapper">
    <#include "../common/navbar.ftl">
    <!--菜单回显-->
    <#assign currentMenu="employee"/>
    <#include "../common/menu.ftl">
    <div class="content-wrapper">
        <section class="content-header">
            <h1>员工编辑</h1>
        </section>
        <section class="content">
            <div class="box">
                <form class="form-horizontal" action="/employee/saveOrUpdate.do" method="post" id="editForm">
                    <input type="hidden" value="${(employee.id)!}" name="id">
                    <div class="form-group" style="margin-top: 10px;">
                        <label for="name" class="col-sm-2 control-label">用户名：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="name" name="name" value="${(employee.name)!}"
                                   placeholder="请输入用户名">
                        </div>
                    </div>
                   <#if !employee?? >
                        <div class="form-group">
                            <label for="password" class="col-sm-2 control-label">密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" id="password" name="password"
                                       placeholder="请输入密码">
                            </div>
                        </div>
                        <div class="form-group">
                            <label for="repassword" class="col-sm-2 control-label">验证密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" id="repassword" name="repassword"
                                       placeholder="再输入一遍密码">
                            </div>
                        </div>
                   </#if>
                    <div class="form-group">
                        <label for="email" class="col-sm-2 control-label">电子邮箱：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="email" name="email" value="${(employee.email)!}"
                                   placeholder="请输入邮箱">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="age" class="col-sm-2 control-label">年龄：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="age" name="age" value="${(employee.age)!}"
                                   placeholder="请输入年龄">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="dept" class="col-sm-2 control-label">部门：</label>
                        <div class="col-sm-6">
                            <select class="form-control" id="dept" name="dept.id">
                                <#list depts as department>
                                    <option value="${department.id}">${department.name}</option>
                                </#list>
                                <script>
                                    $('#dept').val(${(employee.dept.id)!})
                                </script>
                            </select>
                        </div>
                    </div>
                    <div class="form-group" id="adminDiv">
                        <label for="admin" class="col-sm-2 control-label">超级管理员：</label>
                        <div class="col-sm-6" style="margin-left: 15px;">
                            <input type="checkbox" id="admin" name="admin" class="checkbox">
                            <#if (employee.admin)! false>
                                <script>
                                    $("#admin").prop("checked", true);
                                </script>
                            </#if>
                        </div>
                    </div>
                    <div class="form-group " id="role">
                        <label for="role" class="col-sm-2 control-label">分配角色：</label><br/>
                        <div class="row" style="margin-top: 10px">
                            <div class="col-sm-2 col-sm-offset-2">
                                <select multiple class="form-control allRoles" size="15">
                                    <#list roles as role>
                                        <option value="${role.id}">${role.name}</option>
                                    </#list>
                                </select>
                            </div>

                            <div class="col-sm-1" style="margin-top: 60px;" align="center">
                                <div>
                                    <a type="button" class="btn btn-primary  " style="margin-top: 10px" title="右移动"
                                       onclick="moveSelected('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-menu-right"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="左移动"
                                       onclick="moveSelected('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-menu-left"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全右移动"
                                       onclick="moveAll('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-forward"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全左移动"
                                       onclick="moveAll('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-backward"></span>
                                    </a>
                                </div>
                            </div>

                            <div class="col-sm-2">
                                <select multiple class="form-control selfRoles" size="15" name="ids">
                                    <#list (employee.roles)! as role>
                                        <option value="${(role.id)!}">${(role.name)!}</option>
                                    </#list>
                                </select>
                            </div>
                        </div>
                    </div>
                    <div class="form-group">
                        <div class="col-sm-offset-1 col-sm-6">
                            <button id="submitBtn" type="submit" class="btn btn-primary btn-insert">保存</button>
                            <button type="reset" class="btn btn-danger">重置</button>
                        </div>
                    </div>

                </form>


            </div>
        </section>
    </div>
      <#include "../common/footer.ftl">
</div>
<script>

    //左移动 右移动 操作代码
    function moveSelected(src, target) {
        $('.' + target).append($('.' + src + '>option:selected'));
    }

    function moveAll(src, target) {
        $('.' + target).append($('.' + src + '>option'));

    }

    //在编辑页面 若勾选超管 隐藏角色选择框 若取消 再还原
    $(function () {
        var $roleDiv;
        $('#admin').click(function () {
            //判断是否是勾选状态
            var checked = $(this).prop('checked');
            if (checked) {
                //如果选中 移除角色的div
                $roleDiv = $('#role').detach(); //detach()会保留所有绑定事件,附加的数据
            } else {
                //如果没有选中 恢复刚刚移除的,把角色div放到超管后面
                $('#adminDiv').after($roleDiv);
            }
        });
        //编辑提交前 先将右边的全部选中
        $('#submitBtn').click(function () {
            //设置右边的所有option为选中状态
            $('.selfRoles>option').prop('selected', true);
            //提交表单
            // $('#editForm').submit();
        });


        //1.把已有的角色id放入一个数组中(右边)
        var ids = [];
        $(".selfRoles option").each(function (i, ele) {
            ids.push($(ele).val());
        })
        //2.遍历所有的角色(左边)
        $(".allRoles option").each(function (i, ele) {
            //3.判断是否存在ids数组中,如果是就删除掉自己
            var id = $(ele).val();
            if ($.inArray(id, ids) != -1) {
                $(ele).remove();
            }
        })

        /* //角色去重
         var roleIds = $.map($('.selfRoles > option'), function (optionEle) {
             console.log(optionEle);
             return $(optionEle).val();
         });
         console.log(roleIds);

         $.each($('.allRoles>option'), function (i, optionEle) {
             console.log(optionEle);
             var roleId = $(optionEle).val();
             if ($.inArray(roleId, roleIds) >-1) {
                 $(optionEle).remove();
             }
         });*/


        //编辑时，如果是超管，隐藏角色分配
        var checked = $('#admin').prop('checked');//这里拿的是checkbox的状态
        if (checked) {
            $roleDiv = $('#role').detach();
        }
    })

    /*$(function () {
        //保存操作
        $('.btn-insert').click(function () {
            //使用jquery-form插件来提交异步表单(有表单时会使用该插件,写的代码比较少)
            $("#editForm").ajaxSubmit(function (data) {
                if (data.success) {
                    $.messager.alert("温馨提示", data.msg);
                    //一秒后自动跳转页面
                    window.setTimeout(function () {
                        window.location.href = "/employee/list.do";
                    }, 1500)
                } else {
                    $.messager.alert("温馨提示", data.msg);
                }

            })
        })
    })*/

</script>
</body>
</html>
